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ABSTRACT 

There exists a need for a simulation program that will enable a 
programmer to simulate systems such as the Naval Tactical Data System 
(NTDS), Marine Corps Tactical Data System (MTDS), Airborne Tactical Data 
System (ATDS), or any other system that uses radar or sonar information 
for operation. A programming project was undertaken using the Control 
Data 1604 Computer (CDC 1604) and the Data Display Incorporated model 
dd65 Display Console (DD65) as the basic hardware. The program developed 
features on-line control of the CDC 1604 by the DD65, display of sim- 
ulated targets and messages on the DD65, control of tracks by operating 
personnel from the DD65, continuous graph output for permanent record 
purposes, and real time or double real time operation. This program 
can be expanded to provide more features of any of the tactical data 


systems by the addition of the appropriate subroutines. 
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1. Introduction. 
1.1 Background. With the development of new weapons systems, there 
has been a renewed interest in the study of tactical methods and the 
importance of command decisions. This first manifested itself in studies 
of abstract mathematical models which later provided the basis for pure . 
computer simulation. By a thorough analysis of the results of the sim- 
ulation, much valuable data on expected system performance was obtained; . 
however, these models did not allow for the man made command decision, 
nor did they operate in real time with a realistic environment. There 
must be a more flexible man-machine interface to allow tactician to 
construct controlled situations at will, to observe directly the effect 
of one or more command decision links, to modify parameters assumed for 
System components, and to provide hard-copy records for a later critique 
of the situation. 
1.2 Proposed Approach. The objective of the thesis project to be de- 
scribed in this paper was to undertake, within the constraints of cur- 
rently available equipment, the implementation of a simulation system 
that would be used as a test vehicle to study any problem that involve 
trajectories. The salient characteristics of the system were to be: 

(1) A flexible, fine grain, three dimensional track generator. 

(2) A direct man-computer interaction capability (i.e. ‘on-line’ 

control). 
(3) A language independent approach to setting up simulated 
tactical situations, 


(4) A modular approach to inserting sub-systems for testing. 


(5) A real time approach to the simulation problem. 





A flexible track generator was felt to be a basic necessity in order 
to provide realistic problem inputs to replace the classical step and 
ramp input functions. The track generator should have the capability 
of duplicating the actual position information available to a surveil- 
lance system, 

In order to take maximum advantage of man-computer interaction cap- 
ability, it was felt there was a need for direct man-computer communica- 
tion as well as pre-programmed communication. To this end, an executive 
routine, that would act as the coordinating routine between the track 
generator, man communication, display, etc., would be developed. The 
executive routine would operate in real time in order to provide real- 
istic simulation. 

1.3 User Capabilities, 

1.3.1 Tactical Data Simulator. A typical tactical data problem (NTDS 

type ) would be one of pre-programmed hostile tracks, one or more surface 
ships on station, and one or more friendly aircraft, each under computer 
(pre-programmed ) or console control. Then either a canned problem or an 
actual problem could be run using the console for track modification, 

By use of the hard-copy critique output, the user may examine one 
or more of the following: 

(1) The quality of the position information generated by his 

Systems equations. 

(2) The effects of various noise environments upon the quality 

of position information. 

(3) The results of tactical decisions made and a comparison of the 

results, of rerunning the problem, with different tactical 


decisions being made. 





1.3.2 Control System Test Vehicle. An example of a control system 
test vehicle would be a test of a Carrier Automatic Landing System. The 
track generator would furnish the fine grain aircraft position data and 
would receive orders from the landing system computers. The stability 
of the Carrier Automatic Landing System, as well as its accuracy, versus 
changing parameters could readily be studied. Using the same approach, 
many different types of control systems could be studied, such as: 

(1) Air to Surface missile systems. 

(2) Surface to Surface missile systems. 

(3) Surface to Air missile systems. 


(4) Subsurface to Air missile systems. 





2. Programming. 
2.1 Programming Language. The following languages were readily 
available to the authors: 

(1) FORTRAN 60. 

(2) FORTRAN SYMBOLIC. 


(3) FORTRAN 63. 


(4) ALGOL. 
(5) SCRAP. 
(6) CODAP. 


In choosing a language, several criteria must be met; 

(1) Ease of manipulating individual bits. 

(2) Flexible input/output routines. 

(3) Availability of diversified library subroutines. 

(4) Flexibility of operation. 

(5) Ease of programming. 
Some of the available languages satisfied several of the desired cri- 
teria, however, it was felt that only FORTRAN SYMBOLIC met all of the 
requirements. In addition, the FORTBIN compiler associated with FORTRAN 
SYMBOLIC is very reliable and libraries may be manipulated at will. For 
these reasons FORTRAN SYMBOLIC was chosen. 
2.2 Initial Programming. Initially, it was decided to divide the 
programming into two areas. These areas were: 

(1) - Executive Control Routine. 

(2) Track Generator. 
It was felt that each Se these areas were independent enough to allow 


for separate work. A general outline of the interface was set down, 
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with the final details left to be established as the programs developed. 
This worked very satisfactorily. 

2.2.) SIMONE, 

2.2.1.1. Basic Philosophy. Upon analysis of the problem, the initial 
frame work was set down as represented by Fig. 2. The system was to 
operate in real-time, therefore, an executive routine would be needed 
and would be the heart of the system. The philosophy of the executive 


routine is found in [14] . Briefly this philosophy is; 


(1) Subprograms are considered for execution on the basis of their 
priorities as system components. 
(2) Subprograms would be listed by priority and this list would be 
scanned sequentially, executing subprograms as they are needed. 
(3) After each execution, the scanning process would be resumed 
starting with the highest priority entry. 
(4) Assumption is made that sufficient computational capability 
exists to perform all assigned tasks. 
(5) A subprogram is executed only when its "flag is set. 
The executive control philosophy is implemented through a method 
of table control. Three tables, Executive Flag Table (EFT), Executive 
Time Table (ETT), and Executive Jump Table (EJT), contain the necessary 
information for executive control. See Fig. 1. There is a one-to-one 
correspondence between these tables. Fig. 3 is a flow chart of the 
Executive Control Program. Starting with this basic routine and the 
functions of the following subprograms, the initial programming was 


undertaken? 





(1) Keyboard Processor 

(2) Radar Processor 

(3) Track Generator 

(4) Display Routine 

(5) Raw Data Routine 

(6) NTDS Routine 
2.2.1.2 Programming and Problems. The implementation of Fig. 3 was 
accomplished with very little difficulty. The executive tables were 
implemented as arrays with the exception of the EJT. The EJT was 
programmed as the addresses of jump instructions in the program. By 
using the philosophy of the computed GO TO of FORTRAN, the appropriate 
jump will be executed based on the EFT index. 

With the basic control routine working, the next step was to deter- 
mine the method by which the DD 65 would communicate with the main com- 
puter. There are two basic methods by which the DD 65 may communicate 
with the CDC 1604. The first is via the CDC 160 and the second is via 
Channel 7. The first method involves the use to the CDC 160 to inter- 
rogate the DD 65 and then to transfer the information from the DD 65 to 
a buffer in the CDC 160 and then finally to transfer this stored infor- 
mation to the CDC 1604. This method is similar to that used in satellite 
operations. [12] The second method provides for direct communications 
between the CDC 1604 and the DD 65 via Channel 7. The latter method 
has two modes of operations with respect to the DD 65, active and 
passive. The active mode involves the use of the interrupt features of 
the DD 65 while the passive mode involves an interrogation similar to 


that used by the CDC 160. The first method using the CDC 160 was not 
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Figure 3. An Executive Control Program 
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chosen due to the desire to keep the programming as simple as possible. 
The active mode of the second method was chosen because of its ability 
to provide continuous control of the CDC 1604. In the passive mode, 
control of the CDC 1604 would occur only at predetermined times. This 
may or may not be desirable. In the active mode, the desired control 
information is transferred to the CDC 1604 instantaneously. This in- 
stantaneous transfer allows for the fastest response to the commands 
originated at the DD 65 console. With these decisions made, the major 
programming was started. 

To program the interrupts, a copy of the MACHINE RESIDENT was used 
to determine the actual address in ey. the clock processor. By 
substituting the address of SIMONE's interrupt routine in lower cell i; 
and by jumping to the clock processor after checking for interrupts from 
the DD 65, the interrupt tests were ready to run. This arrangement 
proved to be satisfactory for the time being. 

As the program developed, changes were made to RESIDENT and con- 
sequently the program had to change. In order to make SIMONE independent 
of any address in RESIDENT, the clock processor was incorporated in 
SIMONE's interrupt processing routine. At this time the double real- 
time feature was also added. 

The next problem was that of how to handle the input functions. The 
first approach was to use a very complicated jump table and flags within 
the subroutines. This approach proved very cumbersome, therefore, a new 
solution was sought. This solution came in the form of a 30 x 3 matrix, 
which composed a control table for Keyboard 2,and a buffer for storage 
of both Keyboard 1 and 2 information. See Fig. 5 for Keyboard 2 
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Control Table. Each row in the matrix corresponds to one of the switches 
on Keyboard 2. The columns provide information that enables the com- 
puter to process the command. 

The problem of display was solved with the development of sub- 
routine PRINT. For a complete explanation see Appendix III. For the 
display, symbols had to be developed by using the vector mode of the 
DD 65. These symbols are shown in Fig. 6. The results were not entirely 
satisfactory. The raw radar symbol was changed to just two vectors end 
to end with the X and Y position located at the junction of the two 
vectors. The remaining symbols are fine for the smaller scales, how- 
ever, they are too large when the display scale is set for 256 miles. 
These symbols are, however, the smallest available with present equip- 
ment and logic. 

As the philosophy of the program expanded, it became evident that 
there must be some type of hard-copy record of each problem run. This 
was the beginning of the critique routine. The initial thoughts 
centered around the use of scratch tapes to have all information and then 
at the end of the problem to provide a graph output. The basic idea was 
to plot one graph that would show all tracks in the xy plane. The 
critique routine was programmed and tested. The results of the test 
showed this method to be feasible, however, some difficulty was en- 
countered. When trying to read the scratch tape, parity errors occurred. 
To eliminate this problem, memory was chosen to be the scratch pad. This 
proved quite satisfactory, however, due to the limited size of the 
scratch pad, only 10 minutes of information could be stored. The 


solution to this problem was another subprogram that would plot a 
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graph every 10 minutes. During the reprogramming, a second graph was 
added that would provide for an altitude profile vs. time plot. The 
last modification included the point plotting of both the smoothed 
position and the actual position at time intervals to be specified by 
the user. 

The radar processor was made very simple. It included the smoothing 
equations normally associated with the "Alpha-Beta tracker. [1]. Ie 
is in this routine where there is much to be done. Several types of 
smoothing and predicting equations are available. Both the NTDS and 
the MIDS systems were studied. 

As the programming continued, the basic frame work was expanded to 
include many routines. These routines are explained in detail in Appen- 
dix I and an explanation of their use is found in Section 4.4.2. 

See Fig. & for final Block Diagram. 
2.2.1.3 Future Expansions. There are many areas for expansion. Some 
of these would be: 

(1) On-line graph plotting on an XY plotter. 

(2) New smoothing equations. 

(3) A more complete intercept routine. 

(4) A more sophisticated display routine. 

(5) Integration of program with FORTSHARE [12] , 

(6) Incorporation of a radar characteristic table. 


(7) A more complete aircraft characteristic table. 
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Final Block Diagram of SIMONE 


Figure 4. 
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BUTTON TABLE LIGHT TABLE TRANSFER TABLE 


Ol 77202 5 PO 
02 77204 6 Pl 
03 77210 6 P2 
O4 77220 T P3 
05 77240 5 Py 
Ll 11302 4 P) 
12 77304 4 P6 
23 T7710 5 P27 
54 77720 8 P28 
D3, 77740 8 peg 


BUTTON TABLE Code from DD 65 Keyboard 2 switch. 


LIGHT TABLE External Function Code for turning on 


Computer Controlled light indicator. 
TRANSFER TABLE = Number of Characters in the name of the 

program called and the address of the 

name. (Used to transfer program name to 


the buffer. ) 


Figure 5. Keyboard 2 Control Table 


14 





(sqzuerpend Ag) 
sToquxs iJepey [Buty 


ry 


4 


ny aa 


aoejing paeTsTyueptuyn ( ) 


-_ 


suTieMmgns peTsTqueptun 


YeIOITY peTsTqyueptug lL) 


(sjueripeny Aq) 


sToquds wepey TeuTETI0 


" 


‘ 
L 


soejung ATpueTiyg 


suTAeuqne ATpuseTAy 


qersItTy ATpueTazy 


y, 


loved 


[7 


is __. | 


I94Uey sdIOJ YSeB, 


dtyg uso 


aoByang aTIzsoy 


suTAemMgNG STTAsOY 


qFBADITY ATTRZSOH 


Display Symbols for DD 65 


> 


Figure 6. 


C 


15 





2.2.2 Subroutine TRAKGEN. 

2.2.2.1 Early Philosophy. The track generator should be able to generate 
several tracks, each of which could be maneuvered in three dimensions at 
the will of the user. It should be able to praduce tracks which could 
simulate aircraft, ships, and submarines. This placed a requirement for 

a very wide speed range capability on the track generator. The track 
generator should be capable of being coupled with a track parameter pro- 
gram which would give each track the characteristics of a particular air- 
craft or vessel. 

It was decided to program the track generator as a very fine grain 
"actual track generator. This would mean very high resolution capabil- 
ity in three dimensions. The user could then feed this data through a 
radar simulator program which would deteriorate the data to simulate a 
specific radar system in a particular environment. 

The subroutine should be able to accept preprogrammed track commands 
and on-line commands from the user. It should then be expanded to allow 
track control from the tactical data system in the calling program. 
2.2.2.2 Initial Programming. The first decision faced in programming 
the track generator was to determine the number of tracks to be generated. 
This number would be dependent on user need, available memory space, and 
program running time. It was felt that there should be a minimum of ten 
tracks available in order to provide reasonable flexibility. The number 
15 was finally chosen mainly because it was convertible to a convenient 
power of two in binary form. 

The first block diagram for TRAKGEN is shown in Fig. 7. Since the 


subroutine would be generating and storing information on several tracks 
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Figure 7. Initial Block Diagram for TRAKGEN 


according to a maneuver (command) table, some initialization of matri- 
cies and flags would be necessary. It was decided to store the initial 
position, course, and speed for each track during this phase of the 
subroutine. Some signal was necessary from the calling program to 
allow initialization at the proper time. The real-time for the 

problem would have to be transferred with each call anyway, so a 

search was made for a way to utilize this as a flag. If the subroutine 
could be called initially with the real-time equal to zero, the initial- 
ization could be accomplished without fear of the flag reappearing later 


in the program and without the need for a separate flag word. 
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All track information is stored in a 15 x 6 matrix composed of 48 
bit computer words. The track number corresponds to the row number in 
the matrix. The columns are arranged as shown in Fig. 8. Since the 
memory requirements for the program were unknown, it was felt necessary 
that track information be packed into the matrix words rather than 
stored in individual words. The number of bits assigned to each var- 
iable was arrived at by trial and error once the maneuver routines were 
programmed, The final size was determined by a requirement for slow 
speed tracking at an angle close to the cardinal compass points. Since 
the computation is done in part in fixed point arithmetic, a slow track 
would have to move far enough to change by one bit in order to maintain 
proper course. This was accomplished by balancing the overall range, the 
minimum track speed, and the calling period and arriving at the necessary 
bit resolution. Bue tracking criterion was that a one or two knot track 
should be able to track at an angle of five degrees off of a cardinal 
compass heading with a calling period of one second. At the same time, 
an overall range capability of + 250 miles was desired. With the number 
of bits allotted, a two knot track can meet the five degree requirement 
with a one second calling period. A calling period of greater than one 
second allows a one knot track to meet the requirement. Similar reasoning 
was used to arrive at the altitude packing. The same number of bits were 
allotted to altitude as to X and Y position for the sake of symmetry. 

The track course was stored in tenths of degrees to allow turning rates 
of less than one degree per second with, fixed point computation. Since 
a floating point capability was available in the computer, all quantities 


were stored in their original units ; i.e., course is stored in tenths of 
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(POS tPOsiTl Arrays: 


X Position 2h bits Y Position 24 bits 


IPOSIT contains the X and Y position information for active tracks. 


IPOSIT1 initially contains the initial X and Y position for pre- 
programmed tracks. After the track is started, IPOSIT1 is used to 
store position information for faded tracks. 


IHEAD Array: 


ee eee Ordered Crs. Course Speed 
BD slats 9 bits l2s bits ee 12 bits 


FFLAG (fade Command flag) 1 bit 
IFADE (fade flag) 1 bit 
ISKIP (keyboard control flag) 1 bit 
Maneuver Code 4 bits 


JHEAD, JHEADI Arrays: 


Ordered Altitude 2 bits Altitude PL pits 


JHEAD contains altitude information for active tracks. 
JHEADI initially contains the initial altitude for preprogrammed 


tracks. After the track 1s started, JHEAD1 is used to store 
altitude information for faded tracks. 


KHEAD Array: 


opare Acceleration Climb Rate - |Ordered Speed 
12 bits Rate 8 bits 16 bits li2 tibabs 


LHEAD Array: 


Maneuver Limit X Fosiclon 
ioebits 9 bits 
Track Number bits 
Maneuver Code 5 bits 


Y Position 
9 bits 
Spare 2 bits 


LFLAG 1 bit (a 1 indicates LHEAD command present) 





Figure 8, Subroutine TRAKGEN Array Formats 
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degrees rather than an artificial unit such as BAMS (Binary Angular 
Measure ). 

The executive routine divides non-initial calls of the subroutine 
into two parts: 

(1) Update maneuver codes. 

(2) Update positions. 

The first section checks the maneuver table to see if any tracks 
are due to be maneuvered at this time. If there are maneuver commands, 
the proper changes are made in the maneuver code stored in the track 
matrix. Maneuver limits and rates are also stored in proper portions 
of the matrix. 

The second section updates all 15 tracks according to the maneuver 
code stored in the track matrix. Initially, a print statement would 
print out what maneuver had been scheduled for each track. After the 
executive routine was functioning properly, the maneuver routines were 
inserted in place of the print statements. 

The first maneuver routines were: 

(1) Constant course routine. 

(2) Turn routine. 

(3) Climb routine. 

(4) Speed routine. 

No provision was made to perform more than one maneuver at a time 
in the initial programming of TRAKGEN, 

The constant course routine takes the track speed per second 
times the calling period in seconds and computes incremental X and Y 


distances and adds these to the original position of the track. 
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The climb and speed routines are similar and simply increment 
altitude or speed linearly for the number of seconds in the calling 
period. 

The turn routine was the last maneuver section programmed and 
was the most complicated due to the fact that a track can arrive at 
a given course by turning in either direction. Two methods of generat- 
ing a curved track were studied. The first was a computation based on 
turning radius, bank angle, speed, and turn center position. (18). 

The second method was a straight line approximation based on speed and 
turn rate only. After trying both methods, it was decided that the 
straight line approximation gave satisfactory results with less compu- 
tation. The turn routine geometry is shown in Fig. 9. In order to 
insure stability and uniformity regardless of the calling period, the 
track is incremented in one second segments. Only the positions 
corresponding to a calling period time are transmitted to the calling 
program. If a turn will be completed in less than the number of seconds 
available in the calling period, the track is incremented in one second 
segments until just short of the ordered course. Then the track is 

set to the ordered course for the final increment. See Fig. 10. 

Tests were run on the turn routine to check the validity of the 
approximation. A 1000 knot track was programmed to perform repeated 
360 degree turns with a calling period of six seconds. A total of 
eight revolutions was made and a graph output showed that the track 
accurately retraced its path on each revolution. This indicates that 
the approximation results in stable arcs and that circles do not 
degenerate into logarithmic spirals. 
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2.2.2.3 Expanding the Program. At this point, the track generator 
was capable of generating tracks which could perform only one maneuver 
at a time. Some method had to be devised to allow multiple maneuvers 
such as a climbing turn. It was felt that a proper choice of maneuver 
code table and maneuver sequencing could solve this problem. 

There are two possible methods of controlling the tracks by maneuver 
codes. 

(1) Insert a code to initiate the maneuver and insert a separate 

code to stop the maneuver. 

(2) Insert a code to initiate the maneuver along with the desired 

maneuver limit and rate. 

The second method was chosen since it reduces the number of maneuver 
table entries by a factor of two. [It also corresponds to the normal 
method of giving commands to operating units in the fleet. Many forms 
of maneuver code table were tried and discarded as being too cumbersome. 
There are three basic maneuvers, turn, climb, and accelerate. If these 
are equated to maneuver codes of two, three, and four, the simple 
addition of desired maneuvers will result in a distinct maneuver code 
for all possible combinations of maneuvers. These are shown below: 

Turn (basic command), 
Climb (basic command). 
Accelerate (basic command). 
Climbing turn. 

Accelerate in a turn. 


Accelerate in a climb. 
Accelerate in a climbing turn. 


LO A ONWT FD 


To fit in with the addition or subtraction of maneuver codes, the code 


of zero was assigned to a constant course, speed, and altitude track. 
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These maneuver codes are internal to the program; the external codes 
being turn, climb, and accelerate only. 

Since the only external codes being used were two, three, and four, 
this left all other unused numbers available for other functions. The 
external maneuver code decided upon is: 


Start track. 
Turn. 
Climb/dive. 
Change speed. 
Fade. 

Unfade. 

Scrub track. 


MOON Fw Nh = 


The fade command allows a track to disappear from the position 
array while still being capable of performing all maneuvers. The unfade 
command returns the track to the position array for normal display. 
The maneuver code seven is unused. 

In the initial program, the maneuver table was read in during the 
initial call and stored in memory. This severely limited the size of 
the maneuver table. For this reason, the maneuver table was changed 
to a data deck table and only one maneuver entry at a time is stored 
in memory. Each maneuver table entry contains: 

(1) Maneuver execution time. 

(2) Track number. 

(3) Maneuver code. 

(4) Maneuver limit. 

(5) Maneuver rate. 

Besides being controlled from the programmed maneuver table, it 
was desired that tracks be able to maneuver according to the dictates 


of the user or according to the computations in the data process section 
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of the calling program. In order to avoid redundency, it was decided 

to convert the necessary commands into the same form as that read from 

a maneuver table data card and to insert these into the program in place 
of data card information. From this point on, the information is 
processed the same as a maneuver table entry. 

Two sections in the program were developed to handle the interface 
between the input command and the main subroutine. The Keyboard 
Control Section is designed to handle commands from the DD 65 console 
keyboard. It performs checks on the command information to determine 
if the track called for is available for control. It also sets a flag 
in the track matrix to disallow further preprogrammed commands since 
they will be meaningless once the track has been displaced from its 
preprogrammed track. The one exception to this is the keyboard fade 
or unfade commands which do not alter the track path and, hence, do not 
disallow maneuver table commands. All tracks are available for keyboard 
control with the exception of preprogrammed tracks which have not yet 
been started by the maneuver table command. 

The Data Process Section can control any number of tracks simulta- 
neously. It processes the information from the tactical data section 
of the calling program into a form suitable to be fed directly into the 
Keyboard Command Section. Input command information flow is shown in 
Fig. ll. 

2.2.2.4 Future Expansion. Subroutine TRAKGEN can be expanded in 
several areas. The input maneuver code could be changed so that input 
commands are inserted in plain language for convenience. The Hollerith 


word then would select the internal numerical maneuver code. 
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Figure ll, Command Flow Paths 


Since the memory capacity of the 1604 has not been fully utilized, 
it is possible to expand the capability of TRAKGEN to handle more tracks 
or to have greater range capability. Trakgen requires an additional 
nine words for each track and the calling program SIMONE requires another 
70 cells to allow expanded scratch pad space for each track. The range 
capability can be expanded by eliminating X, Y, and Z packing and using 
a complete word for each quantity. This would also allow greater resol- 
ution and consequently slower speeds and slower accelerations. 

Another expansion of TRAKGEN would be the provision for negative 
track speeds to allow ships and submarines to back down. This would 
entail a reworking of the IHEAD array and the pack/unpack sections 


pertaining to speed and ordered speed. 
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To keep up with today's high speed aircraft, it would be well if 
the subroutine could accept maneuver rates in terms of maximum allow- 
able g-forces on the aircraft and pilot. A section could be programmed 
which would compute these forces as functions of speed and altitude. 

In this context it would be well to make provision for entering aircraft 
speeds in mach number as well as well as knots. The g-force section 
would also prevent aircraft from performing maneuvers which in real life 
would be physically impossible. It is advisable when doing this to 
avoid including any classified aircraft parameters to avoid the nec- 


essity of classifying the program. 
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3. EQUIPMENT. 


3.1 cpdC 1604. The CDC 1604 is a stored-program, general-purpose 
digital computer, with a storage capacity of 32,768 48 bit words, 
designed to solve large scale scientific problems and to handle large 
volume data processing. 

The input-output section of the computer handles the flow of in- 
formation to and from the computer. The computer communicates with 
external equipment on one of seven channels. Six of these channels 
are independent buffer channels which provide for the normal input-output 
exchange of data. The input-output channels are paired, channels 1 and 
2, channels 3 and 4, and channels 5 and 6. Channel 7 is a high-speed 
(4.8 usec per word) transfer channel on which up to eight different 
equipments may be connected. All communications between the CDC 1604 
and the DD 65 were on this channel. By use of the CDC 160 computer as 
a buffer, communications can be established with the DD 65 using 
channels 5 and 6. This latter method is similar to that used in the 
Satellite System. 12 
3.2 DD 65. The DD 65 consists to two units, the display console and 
the logic unit. The display console consists of two 12-inch electro- 
statically deflected tubes, Each tube has a usable display area of 
8.5 x 8.5 inches. The left hand tube is normal ly used to display raw 
video from one of several radar inputs. The right hand tube is a non- 
radar tube used to display messages, symbols, etc. 

There are several methods of inputting operator commands into the 
computer. They are by use of an alphanumeric keyboard, a general 


purpose keyboard, a track-ball controller, and a range switch. 
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Switch Designations and Input/Output Codes for Keyboard 2 


Figure 12. 
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The logic unit consists of a 1024 24 bit word core memory. Each 
word is paired to give an effective 512 48 bit word memory. This 
memory can display data at very high refresh rates. There is a switch 
inside the logic cabinet that enables one to use only the lower half 
of memory, thus giving less flicker on the tubes. However, it was 
found that the flicker was not bad and the advantage of extra memory 
far out weighed the slight discomfort of the flicker. 

3.2.1 Command Inputting Devices. The command inputting devices are 
designated as Keyboard 1, Keyboard 2, Track Ball, and Range Switch. 
Keyboard 1 is an alphanumeric typewriter keyboard. There are 64 keys 
keys on Keyboard 1 of which 60 represent different symbols and three 
editing keys, i.e., carriage return, space, and tab, and one unassigned 
key, (code 00). 

Keyboard 2 is divided into three functional sections. See Fig. 12. 

The first section consists of 20 switch units arranged in a 4 x 5 matrix. 
 lhis group has computer selected light indicators and provisions for 
insertion of separately coded switch matrix overlays. By use of these 
overlays, many different functions may be programmed. The second con- 
sists of 4 special switch units. These units are grounded to the 60 cps 
power supply. This enables the switch code to be sent to the computer 
60 times a second without having to hit the key but one time. This 
enables this group of keys to move an editing symbol over the display 
surface. The third section is a group of 10 switches located over the 
alphanumeric keyboard. These have associated computer controlled 
light indicators, Aileen This set of switches is designed to perform 


functions common to all overlay programs. 
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The Track Ball is located to the right of the display tubes on the 
monitor table top. The X and Y coordinate information is available at 
all times to the computer and need only be selected. 

The last command inputting device is not really a command inputting 
device, however, it was used for this purpose. This is the Radar Range 
Switch. This is an 8-position switch which is used to select the 
range of the display. The 8 positions, ranges and associated codes are 


shown in Fig. 13. 


Switch Position Code Switch Position Code 
OFF O 32 k 
h 1 64 5 
8 2 128 6 
16 3 256 T 


Figure 13. Range Switch Coding. 
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4, Usage. 

4.1 General, This routine is intended for use with the normal library 
currently used by the Computer Facility. Complete compatibility has been 
maintained. 

4.2 Program Format. This routine will normally be called from a re- 
serve library tape. However, if the user wants to modify the program 

in order to use his own subroutines, the program will be operated under 
card control. In this case, the following is an example of the normal 


run using the CDC 405 card reader: 


SET , 5000, 66. (Memory scratch pad) 
CALL,1,FORTBIN. (Compiler ) 
FORTBIN,C, 1. (Compiler program) 

PROGRAM SIMONE (Program) 

END 

END 


(Blank card) 

(Blank card needed for card reader) 
SIMONE, 

* Data 


CONTROL, 0. 

To execute this program, load the card reader with the above cards 
and then type on the typewriter, “control,c,p... This will start the 
card reader and all control statements will be printed on the CDC 1612 
printer. 

After the user has checked out his program, the following methods 


are suggested: 
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CALL, 1,FORTBIN. 
FORTBIN,C,1,4. 
PROGRAM SIMONE 


END 

END 
(Blank card) 
CONTROL, 0. 


This will cause SIMONE to be compiled and placed in library 
format on tape 4. A pre-compiled program is ready to run. Due to the 
fact that cells 2000, to 20300, are used as a scratch pad, SIMONE can- 
not be called and run. The following program will allow for the proper 
space being left for the scratch pad: 


SET, 5000, 66. 

CALL, 1,FORTBIN. 

FORTBIN,C,4. 
PROGRAM SIMTWO 
CALL SIMONE 
END 
END 

rp card) 

Blank card) 

SIMTIWO. 

*Data 


CONTROL, 0. 
This program reduces the recompile time from about eight minutes 
to approximately 18 seconds. 
4.3 The Data Cards, 
4.3.1 The first data card contains job identification. It will be 
reproduced on the graph output. Use columns 1 through 8. This iden- 


tification could be in the form of a date, run number, etc. 
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43,2 The second and third data cards contain the necessary arguments 


for the graph outputs; 


(1) XSCALE: Columns 6 through 11. X-scale in units per inch. 


(2) 


(3) 


(4) 


(6) 


(7) 
(8) 


(9) 


The units are miles for the second data card and minutes for 
the third data card. The format is E6.0. 

YSCALE: Columns 13 through 18. Y-scale in units per inch. 
The units are miles for the second data card and feet for the 
third data card. The format is E6.0. 

IXUP: Columns 20 and 21. Distance in inches, of the X-axis 
from the bottom of the graph. Format I[2. 

IYRIGHT: Column 23. Distance in inches, of the Y-axis from 
the left of the graph. Format Il. 

MODEXAX: Column 25. Determine the mode of the X-axis 
location 20 . Format Il. 

MODEYAX: Column 27. Determines the mode of the Y-axis 
location 20 . Format Il. 

IWIDE: Column 29. Width of graph in inches. Format Il. 
THIGH: Columns 31 and 32. Height of graph in inches. 
Format 12, 

IGRID: Column 34, If IGRID = l, a 1" x 1’ will be super- 


imposed on the graph. Format Il. 


The second card furnishes the information for the X - Y position graph 


and the third card the information for the altitude vs. time graph. 


= ty, 


4.3.3 The fourth data card contains SCALE. Use columns 1 through 10. 


Format FlO.O. Due to the variation in altitude capabilities, pro- 


vision has been made to scale the depth information, Any negative 
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altitude will be multiplied by SCALE. This will allow for easier inter- 
pretation of negative altitudes. 
4.3.4 The fifth data card contains IP and IPP. Use columns l and 2 
for IP and columns 5 through 10 for IPP. Format I2 and I6. IP is the 
period in seconds for calling TRAKGEN. All other executive routines 
are called at times based on this period. IPP is the number of sec- 
onds between points on the point plot. If IPP is zero, the point plot 
will not be plotted. 
4.3.5 The sixth data card contains the number of preprogrammed tracks, 
NTRACKS. O€ NTRACKS< 15. Right justify in columns 1 and 2. 
4.3.6 The seventh data card starts the initial position data. There 
must be one initial position data card for each preprogrammed track. 
The position data cards correspond to tracks numbered in consecutive 
increasing number with the last position being for track number 15. 
e.g., if three tracks are preprogrammed, the initial position cards 
are for tracks 13, 14, and 15 in that order. 
(1) X-position in miles in columns 1 through 10. X-position may 
have up to four decimal places. Maximum X is 279 miles. 
(2) Y-position in miles in columns 11 through 20. The same con- 
ments apply as for X-position. 
(3) Altitude in integer feet right justified in columns 25 through 
30. Maximum altitude is + 98689 feet. 
(4) Course in integer degrees right justified in columns 38 


through 40. 
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(5) 


Speed in integer knots right justified in columns 47 through 
50. Maximum speed is 4095 knots. If a zero speed is assigned, 
a non-zero course must be given or the track will fail to 


start when ordered, 


4.3.7 This data card begins the maneuver table. There must be one 


data card for each maneuver. The last card in the table must be a non- 


executable card with a zero in column ten. There is no limit to the 


length of the maneuver table data deck. Entries are: 


(1) 


(2) 
(3) 


Maneuver execution time in seconds right justified in columns 
1 through 10. This time need not agree with a calling time 
since the maneuver will be executed as soon as real-time is 
equal to or greater than execution time. 

Track number right justified in columns 19 and 20, 

Maneuver code in column 30: 

1 Start track. 

2 Turn. 

3 Climb/dive. 

4h Change speed. 

5 Fade, 

6 Unfade. 


8 Scrub track. 


The first code for any track must be a start track command. 


(4) 


(5) 


Ordered course in integer degrees, ordered speed in integer 
knots, or ordered altitude in integer feet as appropriate. 
Right justify in columns 35 through 40. 

Maneuver rate right justified in columns 43 through 50. 
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Insert turn rate in degrees per second with up to one decimal place. 
O.1 Sturn rate < 25.5. 
Insert climb/dive rate in integer feet per minute. 43 < climb rate< 
65535. Insert acceleration rate in integer knots per second, maximum 
CD). 

Any number of maneuvers can be scheduled for the same execution 
time. A track can be ordered to perform more than one maneuver at 
the same time by inserting each maneuver on succeeding cards, e.g.: 


265 12 2 180 i235 
265 12 3 5000 1000 


This orders track number 12 to start a climbing turn to 180 
degrees at a 1.5 degree per second turn rate and to an altitude of 
5000 feet at a climb rate of 1000 feet per minute starting at a time 


of 265 seconds. 
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4.4 DD 65 Operations. 

4.4.1 Hardware. Before starting operations on the CDC 1604, the DD 65 
must be ready in all respects to accept information from the CDC 1604. 
The following check off list is provided to aid in setting up the DD 65. 

1. Check for interrupt /sense relay in place. 

2. Check for cables in place, 

3. Check for memory switch in WHOLE position, 

4. Check for mode switch in 1604 only position. 

5. Check for Power ON. 

6. I£ the CDC 160 output/input cables are connected, insure 
that the CDC 160 is on. If the CDC 160 is not on or is inoperative, dis- 
connect cables. 
4.4.1.1 Interrupt/sense Relay. Several years ago, because of some 
logic problems, a modification to the logic cabinet was undertaken. 

This modification consisted of putting in series with the interrupt lines 
a relay, that was actuated by the power supply. It was customarily re- 
moved when not needed. This year the sense lines were also run through 
this relay. With the advent of the routine of the sense lines through 
this relay, it is possible to leave the switch in the OFF position with- 
out loading down the sense lines of the 1604. For this reason, the 
relay may now be left in permanently. However, before running for the 
first time it will be wise to check this relay. It is located on the 
inside bottom of logic chassis 2. 

4.4.1.2 Cable Connections. Fig. 15 shows the proper connections for 
the cables. These cables are located at the base of the logic cabinet 


just below logic chassis 2. 
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4.4.1.3 Memory Switch. A miniature toggle switch located on the inside 
edge of logic chassis l enables/disables the upper half of memory. Under 
normal use this switch is in the WHOLE or down. position, to make 

maximum use of the memory. 

4.4.1.4 Mode Switch. The Mode Switch is located on the front panel 

of the logic cabinet. This switch has three positions, "160", “Both , 

and |1604''. The normal position for operation of SIMONE is in the 

"1604'' position. 

4.4.2 Console Operations. The following Sections deal with the callable 


routines available to the user. 


44.2.1 CHANGE. 


TASK To maneuver one of the tracks, 
EXAMPLE CHANGE, N, M, L, R, X, Y, Z. $ 
ARGUMENTS t 


N = Track number 


M = Maneuver called--START, SCRUB, PORT, 
STBD, SPEED, ALTITUDE, FADE, OR UN- 
FADE. If the Maneuver called is SCRUB, 
FADE, or UNFADE, then a period and $ 
follow M. 


L = Limit--initial course for START and 
desired course for PORT or STBD. 
This argument is desired speed for 
SPEED and desired altitude for 
ALTITUDE. 


R = Rate--initial speed for START, ten 
times the rate of turn for PORT or 
STBD, rate of climb/dive for ALTITUDE, 
and acceleration/deceleration for 
SPEED. If omitted when interpretated 
as a rate, then standard rates will be 
assumed, 
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4.4.2.2 DESIG. 
TASK 
EXAMPLE 


ARGUMENTS 


4.4.2.3 DISPLAY. 


TASK 


EXAMP LE 


ARGUMENTS 


4ou.2.4 DROP. 
TASK 
EXAMPLE 


ARGUMENTS 


4.4.2.5 GRAPH. 
TASK 


EXAMP LE 


X = Initial X position for START only. 
Y = Initial Y position for START only. 
Z = Initial Z position for START only. 


To designate a track. 
DESIG, TYPE .$ 


2 


TYPE = Type of target-- F will assign 


friendly symbol, H will assign 
hostile symbol, and if omitted, 
ownship symbol will be assigned. 


HOOK = Target under hook will be assigned 


symbol designated by TYPE. 


To change the tube on which raw radar 
data displayed. 


DISPLAY .$ 
O 
This routine will cause the raw data to 


be displayed on the opposite tube from 
which it is now displayed. 


To cause a history track to be erased, 
DROP .$ 


1 


HOOK = Target under hook will have its 


history track erased. 


To cause a graph to be plotted. 


GRAPH .$ 
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ARGUMENTS 


44.2.6 HISTORY. 
TASK 
EXAMP LE 


ARGUMENTS 


4.4.2.7 HOLD. 
TASK 
EXAMPLE 


ARGUMENTS 


4.4.2.8 INFO. 
TASK 
EXAMPLE 


ARGUMENTS 


O 

This routine will cause a graph to be 
plotted that will cover the period from 
the last regular plot to the present 
time. The next regular plot will 

cover the time from now till then. 


To cause history points to be displayed, 
HISTORY,A,M.$ 


3 


A = Number of points desired. This 
must be between O and 24. A nun- 
ber over 24 will be reduced to 24. 
If omitted, l2 points will be 
plotted. 


M = Point mode indicator. If omitted, 
points will be plotted every period. 
M will cause points to be plotted 
every minute. 


HOOK = Target under hook will have its his- 


tory plotted. 


To cause the problem to pause. 

HOLD .$ 

O 

This routine puts the program into a 
wait loop. This wait loop is terminated 


upon the second striking of the HOLD 
switch. 


To provide information on targets, 
INFO .$ 


1 


HOOK = Information about target under hook 


will be displayed. See Appendix I 
for format. 





4.4.2.9  INTCPT. 


TASK To initiate an intercept. 
EXAMPLE INTCPT,C.$ 
ARGUMENTS 2 
C = CAP number of interceptor 
HOOK = Target under hook will be intercepted 

by CAP 
4.4.2,.10 LAUNCH. 
TASK To launch a CAP, 
EXAMPLE LAUNCH,C,R,B,T.$ 
ARGUMENTS lh 


C = CAP number of CAP to be launched 


R = Range from the TASK FORCE center of 
CAP station 


B = Bearing from the TASK FORCE center of 
CAP station 


T = Type of CAP (2 through 7) 


If arguments R and B are omitted, 
Station will be assumed to be under 
hook, If argument T is omitted, 

type / interceptor is assumed. To 
designate type and use hook for sta- 
tion, zeros must be placed in R and B. 


44 .2.@ip SKIP, 


TASK To cause an intercept to be skipped. 
EXAMPLE SKIP,C.$ 
ARGUMENTS L 


C = CAP number of intercepting CAP 
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ieee. 12 STATE. 
TASK 
EXAMPLE 


ARGUMENTS 


4.4 .2,13 STATION, 


TASK 
EXAMP LE 


ARGUMENTS 


4.4.2.14 STEER, 


TASK 


EXAMPLE 


ARGUMENTS 


4.4.2.15 STOP, 
TASK 
EXAMPLE 


ARGUMENTS 


To display the State of the CAP, 
STATE,C.$ 
1 


C = Cap number. State format in 
Appendix I. 


To Station a CAP, 
STATION, C,R,B.$ 
3 

C = CAP number 


R = Range from TASK FORCE center of CAP 
station 


B = Bearing from TASK FORCE center of 
CAP station 


If R = O, then station will be assumed 
to be under the hook. 


To cause a CAP to be sent to TASK FORCE 
center. 


STEER,C.$ 
1 


C = CAP number 


To terminate the problem, 


STOP .$ 


0 


4h 





Woh .2.16 
TASK 
EXAMPLE 


ARGUMENTS 


BEGIN, 
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To start the problem. 


4 


BEGIN.» 
0 


This routine starts the problem 
and the number of tracks under 
user control is displayed on the 


DD 65. 
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Figure 15. Cable Connections 
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5, Equipment and Logical Difficulties. 


Some difficulties were encountered which were the result of both 
equipment logical short comings and equipment interaction. 

5.1 DD 65 Display Console. Keyboard 1, the alphanumeric keyboard, 
when selected for input remains selected even after the input has been 
completed. If the keyboard were again selected for input, the processor 
is indefinitely delayed when the input is attempted. This limitation is 
the result of the cumbersome electromechanical keying system used, and 
has been previously avoided by selecting another display unit external 
function code. The deselect code previously used was SELECT RADAR 
TARGET DATA TO AUXILIARY EQUIPMENT. This code seemed to work well and 
was used to positively deselect both Keyboards 1 and 2. 

It was also found that when one used the code SELECT RADAR RANGE 
SWITCH followed by SELECT TRACK BALL X' that on some occasions the com- 
puter would be delayed indefinitely trying to input the X-cordinate. 

On the time the 1604 was not delayed, the next time an input from Key- 
board 1 was attempted the code 760 was transferred to the computer. To 
correct for this the code for SELECT RADAR TARGET DATA TO AUXILIARY 
EQUIPMENT was used to deselect again, It appears that whenever an in- 
put code is selected it takes an output code to deselect the input code 
and vice versa. This points out the fact that there is no single code 
that deselects previously set selects. 

5.2 CDC 1604. At this time there still remains an interaction between 
the 1604 and the DD 65 that has not been explained. Occasionally, during 
an update of the DD 65's memory or during an erasing of the DD 65's 
memory, the 1604 ends up with a 00007 in the upper address portion of 
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cell 00007. Since the upper instruction is an unconditional jump, the 
computer just sits there looping on the same cell. The logic prints 

show this to be impossible and the logic cards that actuate the inter- 
rupt lockout have been changed to no avail. At this time there is no 


answer. 
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6. Conclusions and Acknowledgments. 


——— 5 tee eee 


6.1 Conclusions. A general purpose track generator has been imple- 


mented based on the following concepts: 


(1) 


(2) 


(3) 


Suitable for on-line simulation as well as system analysis 
studies, 

Applicable to both anti-air and anti-submarine warfare 
operations. 

Provision for operator interaction made available for 


J s rt vi e 2 2 
exercising console control in gaming situations. 


The tracking package provided is intended to be used as a basic 


tool in: 


(1) 


(2) 


By 


Computer simulation analysis of weapons systems performance, 
e.g., interceptor-missile mission, 

Illustration and evaluation of combat direction system 
functions, e.g., NTDS, ATDS. 

Any system studies requiring complex track motion data on 
multiple targets, e.g., track-while-scan radar system per- 


formance. 


The following major routines have been fully checked out under 


operating conditions: 


(1) 
(2) 
(3) 
(4) 
(ei) 
(6) 
(7) 


Subroutine TRAKGEN (Track Generator). 

Executive Control Routine, 

Display Subprogram. 

Radar Processor Subprogram, 

Keyboard Command Routine (Program Control Routine). 

Graph Output Routine. 

All keyboard callable routines except the HISTORY Routine. 
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In addition, an Aircraft Control Subprogram has been incorporated 


into the program listing. While reasonably close to final form, it 


has not yet been successfully tested with the system. 


In the course of the work several interface problems on the 


1604 - DD 65 channel 7 hookup were brought to light and corrected. 


These problems were: 


(1) 


(2) 


(3) 


The DD 65, when turned off, loading the sense lines of the 
CDC 1604, 

The CDC 1604 being unable to input information from the track 
ball without first positively deselecting any previous input 
selection made by the CDC 1604. 


Incorrect cable listings in (10| for channel {7 hookup. 


In addition, the following engineering difficulties have appeared 


but have not been corrected: 


(1) 


(2) 


(3) 


An apparent random failure of the interrupt lockout feature 

of the CDC 1604 resulting in the computer remaining in a 

loop executing the instruction oSted (9 Ve while PAR equals 
OO0007. 

Apparent incomplete decoding of certain external function 
codes or leaking’ of other signals into the external function 
lines of the DD 65 resulting in random selects of the computer 
controlled light indicators. 

Sensitivity of data transfer to timing adjustments in the 

CDC 1607 tape units resulting in parity errors if they are 

out of tolerance (Not corrected, but bypassed by use of 


memory as a scratch pad). 
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Upon analysis of the data obtained over the past five months, the 
duty cycle has been calculated to range from 0.18 to 0.26. The smaller 
duty cycle occurred during a 15 track problem. These figures were a 
result of the duty cycle routine embedded in the program. They closely 
correlate with theoretical data. The duty cycle indicates that the 
only constraint on expanding the program is that of computer memory 
size. 
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APPENDIX I - A 
Identification. 
Title: SIMONE 
Category: Control Routine 
Programmer: E. L, Borden 
Organization: U. S, Naval Postgraduate School 


Date: April 1965 


Purpose. 


This control routine provides a means to control a simulated 


tactical data system from the DD 65. 


Executive Called Subprograms. 


3.1 1F-Display Subprogram. This program calls PRINT and causes 
both raw and smoothed data to be displayed on the DD 65. 

3.2 1G-Radar Processor. This subprogram uses the basic "a lpha- 
beta. smoothing equations to process the radar data. The equations 
can be found in le 

3.3 1GR-10 Minute Graph Subprogram. This program reads from the 
memory scratch pad and processes the data for calling DRAW to out- 
put the permanent graph record. 

3.4 \LINT-Aircraft Control Subprogram. This program performs the 
bookkeeping on fuel and ammunition loading for friendly aircraft 
and allows for control of these aircraft by the data process 


section. See Fig. I-l for the collision intercept geometry. 
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Collision Intercept Geometry. 


B Bogie 


é7_- Car Course 





eee eee 
X-Ax's 


Alfa = Absolute value of Bogie Course minus Cap Bearing from bogie. 
I = Point of intercept. 
CP = N (Perpendicular distance from Cap to Bogie track). 


BP = M (Distance from Bogie to point P). 
Ve = Velocity of Bogie. 
V = Velocity of Cap. 


Figure [-1l 


I-A-2 
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In order for the Cap to intercept the Bogie at point I, the follow- 


ing equations must be true: 
BI = Vit Q i = Viet 


We assume the following equation to be true. If it is not the case, BI 
will be negative and a collision intercept will be impossible since the 


intercept will take place somewhere to the right of P. 


(cr) = (m-sz)* + N* 


Solving the above equation simultaneously we end up with a quadratic 


equation in BI. 


(ve-V4)* (er) + (amv, )- (81) - v,7(m*+N*) =O 


Solution: 


(BI) + at (a1) - —**— . (m4) = 0 


(Ve?-V (Ve? Vs) 


(fey) (Ey) 


This is the basic equation that must be solved in order to 


BI = Vem [ol be 
(Ve*- V,*) 





determine if an intercept can be made. If two positive values of 


BI exist, the smaller of the two will be the shortest intercept. 
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3.5 1K-Keyboard Command Subprogram. This program sets the range 
scale factor and positions the hook on the right hand tube of the 
DD 65. This routine also checks to see if there are any commands 
from the DD 65 to be executed. If there are commands to be 
executed then control is passed to the 1P-Program Control Routine. 
3.6 1TG-Track Generator Calling Subprogram. This program calls 
TRAKGEN, unscales and unpacks the X, Y, and Z positions and re- 


cords these values on the memory scratch pad for future graphs. 


DD 65 Called Routines. 


4.1 1C-Change Routine. This is a seven argument routine, which 
is used to control tracks. 


4.4.1 Arguments. 


1A Track Number 

CA Maneuver Called 

3A Variable Argument (Limit ) 
LA Variable Argument (Rate) 
5A X Position 

6A Y Position 

TA Z Position 


The variable arguments are interpreted according to the maneuver 


called. The interpretations are: 


Maneuver 3A LA 

START Course Desired Speed Desired 
SCRUB Ignored Ignored 

PORT Course Desired 10 x Turn Rate 
STBD Course Desired 10 x Turn Rate 
SPEED Speed Desired Acceleration 
ALTITUDE Altitude Desired Dive/Climb Rate 
FADE Ignored Ignored 

UNFADE Ignored Ignored 
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Arguments 5A, 6A, and 7A are used only when the maneuver START is 
called, at all other times they are ignored. 
When the argument is a rate (4A with PORT, STBD, SPEED, and 
ALTITUDE), omitting the argument will cause standard rates to 


be entered. These rates are: 


PORT 1.5 Degrees per second 
STBD 1.5 Degrees per second 
SPEED 10 knots per second 
ALTITUDE 5000 feet per minute 


4.2 1D-Display Routine. This is a zero argument routine that 
complements the D-Flag. The Display Subprogram uses the D-Flag 
to determine on which tube the raw data is to be displayed. A 
negative D-Flag will cause the raw data to be displayed on the 
right hand tube while a positive D-Flag will display the data on 
the left hand tube. 

4.3  1J-Designate Target Routine. This routine is a two argu- 
ment routine that calls the 3JO routine to determine the second 
argument. The target under the hook will be designated accord- 


ing to the following: 


Argument Designation 
O(zero) Own Ship 
H Hostile Track 
F Friendly Track 


When a track is designated friendly and it is an aircraft, its 
interceptor type is determined by the condition of the least 
significant bit in cell 50 (Job time clock). A O assigns a type 
7 and a l assigns a type 3. 


tana 
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4.4 1L-History Routine. This routine is a three argument 
routine. The first argument is the number of points desired. 
This argument may be any number between 1 and 24. Any number 
greater than 24 will be reduced to 24. If the argument is 
omitted, then 12 points will be plotted. If the second argu- 
ment is anything other than zero, then the first argument will 
be interpreted as the number of minutes of past history with one 
point for each minute. The third argument, the track number, is 
filled by the Hook Routine. Up to two tracks may have past 
history plotted. If a third track is requested, the first track 
will be dropped. 
4.5 1PQ-Hold Routine. This is a zero argument routine that 
places the program in a wait loop. The second hitting of the 
hold switch will resume the program. 
4.6 1Q-Intercept Command Routine. This is a two argument 
routine that calls the Hook Routine to fill the second argument, 
the BOGEY track number. The first argument is the CAP number 
of the interceptor. This routine sets the necessary flags which 
signal the Aircraft Control Subprogram to initiate an intercept. 
4.7 1R-Drop History Routine. This is a one argument routine 
that has its argument, the track number, filled by the Hook 
Routine. The history being displayed on the hooked track will 
be dropped upon execution of this routine. 
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4.8 1S8-Stop and Critique Routine. This is a zero argument 
routine that causes the problem to be terminated and the final 
graph to be plotted. 
4.9 11ST-State Routine. This is a one argument routine which 
causes one of the following messages to be displayed on the DD 65 
depending upon the actual state of the interceptor. 
STATE REPORT ON CAP XX 
PLUS 
AMMO MINUS / OXYGEN PLUS / FUEL xxxx POUNDS / TIME xxxxZ. 
ZERO 
TYPE x 
4.JO l1TT-Information Routine. This is a one argument routine 


that has its argument filled by the Hook Routine. The following 


are examples of the types of information messages that appear: 


INFORMATION 
TRACK NR 14 
BOGEY E3 


COURSE 350, SPEED 450, ALTITUDE 35000. 
RANGE: 120 MILES, 

BEARING: 80 DEGREES. 

FROM TASK FORCE CENTER 


INFORMATION 
TRACK NR 13 
SKUNK D 


COURSE 35, SPEED 13. 
RANGE: 12000 YARDS. 
BEARING 270 DEGREES. 
FROM OWN SHIP 
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INFORMATION 
TRACK NR 3 
GOBLIN E 


COURSE 270, SPEED 4, DEPTH 200. 

RANGE: 3000 YARDS. 

BEARING: 5 Degrees 

FROM OWN SHIP 
Speeds are in knots and depth is in feet. 
4,11 1lU-Steer Command Routine. This is a one argument routine 
which sets the necessary flags which signal the Aircraft Control 
Subprogram to steer the CAP specified by the argument. 


4.12 1lv-Station Command Routine. This is a three argument 


routine. The arguments are: 


1A CAP number 
CA Range of Station from TF Center 
3A Bearing of Station from TF Center 


If argument 2A is zero or omitted, then the station will be 
assumed to be under the hook. This routine sets the necessary 
flags which signal the Aircraft Control Subprogram to station 
the CAP. 

4,13  IW-Skip Command Routine. This is a one argument routine 
that sets the necessary flags which signal the Aircraft Control 
Subprogram to cause the CAP listed in the argument to disengage 
and return to station. 

4,14 1X-Launch CAP Command Routine. This is a four argument 


routine. The arguments are: 


1A CAP number 

OA Range of Station from TF Center 
3A Bearing of Station from TF Center 
LA Type of interceptor 
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If argument 2A is zero or omitted, then the hook is assumed to be 
over the station. This routine sets the necessary flags which 
signal the Aircraft Control Subprogram to launch a CAP and send 
him to the designated station. 
4.15 1Z-Begin Routine. This is a zero argument routine that 
starts the program and calls TRAKGEN with time equal to zero. 
This routine also causes the number of tracks under Keyboard 
control to be displayed on the DD 65. The format of the message is: 


O7 TRACKS UNDER YOUR CONTROL. 


Control Routines, 


5.1 1T Executive Control Routine. This routine follows the 

basic philosophy of the executive control routine described in 
Section 2.2.1.1 of the main body and in [14] : 

5.2 I1P-Program Control Routine. This routine functions as the 
basic operator-computer communications link, decodes control state- 
ments, packs arguments for routines; then passes control to the 


routine designated. 


Miscellaneous Routines. 


6.1 3JO-Hook Routine. This routine is used by many other 
routines and cannot be called separately. It hooks any track 
within the range acquisition gate. The range acquisition gate 
is variable and changes depending upon the range scale setting. 


The gate sizes are: 


oer 





— 
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Range Scale (miles) Gate 
256 SeO x. e060 
128 IO x 1h.0 
64 220 x 2,0 
Be iO lO 
16 ole me, 
8 ag ee meas. 
ee Diese hes 


There is no acquisition gate for altitude. If two or more 
targets are within the X and Y gates but at different alti- 
tudes, the target with the lowest track number will be hooked. 
If there is no target within the gate, the error message "TRACK 
NOT HOOKED will be displayed and control will return to the 
Executive Control Routine. 

6.2 lyY-Find CAP Number Routine. This routine is used in con- 
junction with any routine that uses CAP number instead of track 
number as an argument. This routine searches the TRACK array to 
determine the track number of the CAP. If the result of the 
search is negative, the message "CAP xx NOT AIRBORNE. is displayed 
on the DD 65. 

6.3  1ZZ-CAP Number and Station Routine. This routine calls the 
CAP Number Routine to determine track number and then computes 


the X and Y coordinates of the designated station. 


Error Stops. 


An incorrect number of tracks, i.e. number greater than 15, on the 
sixth data card will cause the program to execute a selective stop. 
The following error message will be displayed. 

NTRACKS 2 16 CHECK DATA DECK AND TRY AGAIN 
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The program may be started again after correcting the data deck 
by hitting RUN on the CDC 1604. 


8. Error Messages. 


Message Meaning 
PROGRAM NOT CALLED The program called was not 
listed in the Program Name 
Table. 
TOO MANY ARGUMENTS Too many arguments were listed 


for the program called or an 
unauthorized argument was used 
(i.e€.2,:,A5 etc.) 


OND ARGUMENT ILLEGAL An illegal maneuver was called 
for or the argument for the 
Desig Routine was not on 
H, P, or O (zero). 


TARGET NOT HOOKED No target was within the 
range acquisition gate. 


NTRACKS 216 CHECK DATA DECK AND TRY AGAIN 


See 7. 
9. Information Messages from Aircraft Control Subprogram. 
Message Meaning 
CAP xx UNABLE TO INTERCEPT - FUEL CAP does not have enough fuel 


to reach the intercept point 


CAP xx UNABLE TO INTERCEPT - AMMO CAP does not have any ammuni- 
tion left aboard 


CAP xx LOW STATE CAP has just enough fuel to 
return to carrier 


CAP xx MAYDAY...MAYDAY... CAP out of fuel, Ditching 
CAP xx INTERCEPTING - UNABLE TO RETURN CAP does not have sufficient 
fuel to return to the carrier 


after making an intercept 
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CAP xx FAMISHED 


CAP xx POOR INTERCEPT 


SPLASH BOGEY Exx 


HEADS UP BOGEY Exx 
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CAP has no station assigned 
CAP unable to make collision 
intercept and is in a pursuit 
intercept 


CAP destroyed BOGEY Exx 


CAP unable to destroy BOGEY 
EXxX 


_ 


soreull fac | BS Bert 


| 4SOWSTTA . | 


_ : 
Ae. 


GaneIMAY 
THSOMNTML MOOG ne A 






<a 720008 HEATS 


ene 67 FU Bae 
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10, Array Formats. 
10.1 TRACK Array. 


213 IS IS 


Friendly Bit Symbol Designator 
Surface Bit | Steered Bit 
Aircraft Bit Pursuit Bit 
Submarine Bit Collision Bit 
Spare Bits Orbit Bit 
Type Interceptor Launch Bit 
Target Number Steer Bit 

Skip Bit 


Station Bit 
Intercept Bit 


10.2 TRACK Array. 


is 6 7 G /8 
em lmebeiS la connyes bits bits 


Spare Bits 

Y Station 

X Station 

BOGEY track number 
CAP track number 
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Interrupt Routine 


Interrupt Processor Clock Processor 


No RESET ONE 


SEtConn cou 
Yes 
Keyboard 1 Z A 
SELOVD Count 


NOTSET 
INCREMENT 
TIME CLOCK 


ERECT 
ARACTS | 


Caine 


3 





Figure I[-2 
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Keyboard 1 Processor Keyboard 2 Processor 


Resicters 


ECNPUT FROM 
KEXBOARN 4. 






Save A ano Q 
REGIS TERS 







Pause 
FRAG SET 


ELGSig SNES _ 
PARENTHE ¢! ie A _ ay. 


LNPUutT FROM 


No KEYBOARD 2 
MASK 
Perion Ne sae ee | MATRIY CO0E 
No 


INDEY ow 
BUTTON TABLE 







Yes 
CARRIAGE 
RETURN 


No 
TRANSFER To 
Y BUFFER 
ie oA PROGRAM 
/ NAME 
No , 


Stove Ineour 
in Buffer 


Decelect 
Interru et 


Sh A. 





Restors Annag 
Reoisrers 


Figure I-3 
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Pause Check Routine 


INPUT FROM 
KEY Bo#rD ye 





MASK MATAIY 
CoE 


PAUSE FLAG 
= =ERO 


lecee@ge 


STOR PERioa 
OR ChOSING PARE 






ASSEmBiLE 
BuUPFER WTO 





EK 
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Erase on CR 


RESET Bureee 
POINTER 


TURN ore 
ERROR LT 


TURAN ore 
OTHER LTS 


ZERO out 
BUFFER 


ERASE ppb 6S 


MEMORY (484-Si0) 


Be 


Figure I-4 
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Change Routine 


De 15 











Bo) LTE 


Ber 


GDNWUYIS 


2a 5NN 


30t4 


GQaAdsS 


FOMLILTEY 


Gels 


ALUOd | 


AUHLS 





d 
BI0D NYW 


NaNhaNuaW 





Bwyois 





Yadunn 


ADHB, Avis 





Figure I-5 
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Storage Routines 


Senter 
IAG! 196 


Sinan nowy 
AN Ovazg 











Zon L1( L144 
3yous 





JY S/ 








a 
FLOM LS 


~ 
aSaUnond 
JYOILS 


THO3Z4IT Lvaw 


“N9OUY NZ, 
TSw Woyug 
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Figure I-6 
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Error Message Routine 


TURN ON 
ERROR KT 


ASSEMBLE 
~—CE RR OR 










MESS AGE 


RESET BuFl 
PoinTeR TOA 


OuUTePUT 





Figure I-7 
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Display Subprogram 


CALL PR 


SET DisPrl any’ 
TF CENTER 
RET DISPLAY 
FoR JEFT Ham 


0 


S 









SEARCH Trent 
For MANcbesg 


Yes 






SEARCH Track 
FoR wow Active 


MAN CODE: § 
Now Acrivic ba 
TRACK 





/ 
SEARCH Ewen SET TRAGIC | 
| Fon PAE weiT | (| TO NovActive. 
N. 
FADE Gi DETERMINE 
ae QUADRANT 
Yes SET APPROPRIATE 
SYM iIBOW 
Xe 
RTI 1LFO 
Load XV pwn Ya) 
Ny 


STORE GL) Syne 
SET Toe NW ACTIUZ 





CALL 





PRINT 
CRaw Dara) 
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Display Subprogram (cont) 


tATE Kis 










CALL 
PRINT 
CAISTORY 
CALK a 
PRIWT 


CcentExs) 


Yes 
Mo RE 
reac 


No 









RTS 2FOo 


KOAD yHIS2 Aw 
YHis2 





Figure 1-9 
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Load X and Y Routine 
SCALE xX 
& 
ivy PRINT 


Scare Y 


2 


Ser VWareines 
IW) Prin 


> 


Figure I-10 
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Radar Processor Subprogram 





Senacn For 
Now Ache Trecks 
Now AcTive 


Yes 
TRACK 


AF 
Equarions 
Yes Nee Ves 
Ue PATE 


UP DATE 
HISTORY 4L 


<r 


UP PATE 
y, HISTORY ro, 













Figure I-11 
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Radar Processor Subprogram (cont) 


Botr 
X ANB Y PERO 









: 


Senrcn Fon 
Fonmer FADED 
TRACK 


=< Yes Reser SvmGok 
FAom KAT TRACK 









SET SymBou SET SX¥MRBoK 
For AJ& FoR Sureeace 


LTuitriagynite 


SMOOTRE D 
POSITIONS 


SET SymaBon 
Fon SUB 


Figure I-12 
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Aircraft Control §ubpragram 


TINT 


SAVE INDEX 
REGISTERS 


SET ARRAY 
COUN TERS 


IIS 


: 
9) 


NO 


= 50) ie 


' 








11K 





FRIENDLY 
AIRCRAFT 


DNs 

by 

Pa 

~ 
™ 


NO 





(ee 
COMPUTE Fuet 
CONSUMPTION, 
INCREMENT Close UP 
TRACK 1 ARRAY, 
SET_ TRACK 1 
POINTER 
E. 
Joe oO RESTORE INOEX 
REGIS TERS 










MESSAGE 
ALREADY 
SENT 


YES 


NIE 


Figure I-13 
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Send Message Routine 


wT eew Dp 
UNABLE To 
RETURN” 
MESS AGE 


“FAmMISHED” 
MESS ACE 





(en 


i SEND 
UNABLE To 


INTE RCE PT - Aang 
MESSAGE 


4 IE 









SEN O 
"UNABLE TO 


INTERCEPT - Fle 
MESSACE 









Sh iL 


SET SKIP 
BT 
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Intercept and Skip Routines 


ComPuTe RANGE 


AyD BEARING 
TO BOOGIE 


CLEAR INTERCE 

ANO Skip BITS, 

PESIGNATE AS 

UNEMCACED CAP 
AYO B0G)E 





No 





SET Collision 
FLAG 
STATIOW Yes 
AVAILABLE, 11S 
YES 
oO 


NO 
Sem One jy a 
is iT 
SET PURSUIT 
FLAG 
SIE 










SPARROWS No 
ON BoARD 
YES SET NO 
SPARROW 
FLAG 


tohG 


(Te 





No 


5S1E 


YES 
Figure I-15 
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Collision Intercept and Station Routines 


C COMPUTE 
COLLISIo0N 
INTERCEPT 
No 
YES 
SET ENGAGED 
FLAG 









(ells 


HiT oR miss 





YES 
GIVE CAP 
INTERCEPI ee 
ORDER 
No 


FIRE SEConD 
SPARROW 










Compure 
COURSE To 
STATION, GIVE 


ORDER To CAP 





Figure I-16 
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Pursuit Intercept and Steer Routines 






1IP 
Zale 

(city ComPuTE PUR Suir 

YES INTERCEPT, Gly 

ORDERS TO cAP 

No 
Yes 
YES 1 ‘a 
NO 


Qe 


1IR 












CAP Ac 
MORE 
SPARROWS 
OM 
i 7 








ALREADY 
STEERED 


YES 






FIRE SECOND FIRE SEConwD 
SPARROW SIDE WIDER 


128 las 










ORDER LETDE6WH 
AM) DECELE RATIO 
AT PROPER RANCE 











GIVE ORDER To 
CAP TO RETURN 
TO CARRIER 





Figure I-17 
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Orbit Routine Launch Routine 


REeseT LAumcyY 


B1T, LAUNCH 
CAP 


Say 
ORBIT BIT 


ORDER CRUISE 


SPEED AND 
ALTITUDE 









ORDER 
OX BIT" 


SPLASH 
BOtGleE 





Figure I-18 


I-B-17 





APPENDIX I-B 


Designate: Track Routine 


TURN oFF 
DEstg LT x > 


RTS BIO 
Hoo. Track 


Y SET Smoot For > 
OWN suid 
1 GET S¥mBol For 


Ee 
Ye - SET SYMBOL FoR 
—e = HOSTILE sip 
PS 


= 
: 











SET FR\ewniy 
SHV Numgen. 


Yi SET HosTrice 
= 
> ee SHIP NUMBER 


Ny 
SET SHIP BIT 
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Identification. 


Title: TRAKGEN 


Category: Track Generator 
Programmer: AC Casciato 
Organization: U. S. Naval Postgraduate School 


Date: April 1965 


Purpose. 


This subroutine is designed to generate fine grain, three dimen- 
sional position information in order to simulate radar or sonar 
track information. The subroutine generates up to 15 tracks 


simultaneously. 


Program Sections. 


3.1 I1RET - Subroutine Entry, Initial Call. This section checks 
for the initial call and initializes all arrays and flags, reads 
in the initial position data for preprogrammed tracks, and sets 
all tracks to standby. 

3.2 I1TRAK - Process Maneuver Table Entries. This section reads 
in maneuver command data from the Data Process Section, the Key- 
board Command Section, and the Maneuver Table and updates the 
maneuver code in the track matrix. It selects the proper maneuver 
section for track processing. 

3.3 IWAIT - Utility Section. This section contains several small 
sections used by other portions of the subroutine. 

3.4 I 1MOVE - Update Tracks. This section unpacks the track matrix 
information and routes the data through the proper man#uver routines 


T{-A-2 








APPENDIX II-A 
in the necessary order, After processing, the data is repacked 
into the track matrix. 
3.5  1EXIT - Exit From Subroutine. This section restores the index 
information and returns control to the calling program, 
3.6 1GO - Constant Course Section. This section increments X and 
Y position information when the track is not in a turn, 
3.7  1TURN - Turn Section. This section processes the X and Y 
position information when the track is in a turn, 
3.8 IDIVE - Climb Section. This section increments the altitude 
information when the track is climbing/diving. 
3.9 I1SPD - Speed Change Section. This section increments the speed 
information when the track is changing speed, 
3.10 1CT - Multiple Maneuver Section. This section sets the proper 
flags to route the track information through the necessary maneuver 
sections when performing more than one maneuver. 
3.11 LKEY - Keyboard Command Section. This section processes key- 
board command information into a form similar to that of a maneuver 
table data card. 
3.12 KEY - Data Process Command Section. This section converts 
tactical data command information into the form of keyboard command 


information. 


Limitations on Subroutine Quantities, 


4,1 The maximum and minimum values for subroutine TRACKGEN input 


quantities are: 
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X and Y position: ee mese 

Altitude + 98,689 feet. 

Course: QO to 360 degrees. 

Speed: O to 4695 knots. 

Turn Rate: O.l1 to 25.5 degrees per second, 
Climb eee 43% to 65,535 feet per minute. 
Acceleration: 1 to 255 knots per second. 


* The climb rate has a minimum or 44 1eet per minute with a calling 
period of one second. With the six second calling period, a minimum 


climb rate of eight feet per minute is possible. 


Rules Governing Track Commands. 


5.1 The first command for a preprogrammed track must be a "Start 
Track command. 

59.2 More than one command may be given to the same track at the 
Same time. 

5.3 Normal maneuver commands may be given to a track even if it 
has been faded. 

5.4 Once a track has been maneuvered by the keyboard console or by 
the data process section, further preprogrammed commands are ig- 
nored, This does not apply to the keyboard "Pade or 'Unfade’ 
commands, 

5.5 A track which has been scrubbed by any means cannot be restarted 
from the preprogrammed data deck, 

5.6 Any maneuver may be continued to a new assigned limit by in- 
serting a maneuver command with the new limit. The previous maneu- 
ver does not have to be completed before ordering the new limit. 
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SUBROUTINE TRAKGEN FLOW DIAGRAMS 


Subroutine Entry and Exit 


SCALE And PACK 


INITIAL Pos 
ITiens DATA 





SAVE 
INVE X 
SET 
WE CISTERS TRACKS To 
STANDBY 
pay 9 ies 
FLAGS 
VES To ZERO 


STrel 
REAL TIME 
CLOCK 


START 
REAL TIME 
Cio CK 


FOAM 


INSENT NUOMEEKR 
OF VEN PRL = 
PNOCE RANA a 
TNAEKS INA WEE 


SCALE 
FACTORS 





yw 
ARRAYS 


TO ZERO 





TEXIT 


READ NUMBER 
oF 


PRE PRog RA MME 
TRACKS 





STORE 


PEAL TIME 





Yes 
1 SAVE 





RESTORE 
/MDEX 







READ INITIAL 
POSITION 
DATA 

CARDS 


REGISTERS 





Figure II-1 
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Update Maneuver Codes 


STror 


REAL TIME 
COMPUTE RESET CLocK 
CALLING KEY BOARD 
FLAG 






READ 
MANEUVER 
DATA 
CARD 







START 
REAL TIME 
Clock 









UNEXECUTE D 
MANEUVER 





VES 
RETURN 
No 
YES STRAK 
CALLING YES YES 
PERIOD =0 {SAVE 
—o \ 


Figure II-2 
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No 
CommAYvD 2TRAK 
FADE YES 
COMMAND TFADE 
Ne 










MAMEUVER Cod 
jo oLpd 
MAX EuvEerR CODE 













PACK MANEUVER 
LIMIT AMD FA 
/MTO PROPER 
WORDS 


2aTRAK 
ES 
f 1STOP 


YES 
2TKAK 


Figure II-3 
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STAN OBY 
TRACK 


NO 


RESET FADE 


FLAG =O 





TRACK 
FADED 


RESTORE FOS sTia 
PAN, Se] 
FADE FLAG =! 


UN FADE 
TRACK 
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Update Track Positions 


UNPACK PQS/TIon, 

COURSE, SPEED, 

AND MANEUVER 
CODE 





REPACK POSITION, 
COURSE, SPEED, 
AWD MANE VVER 















STORE 
POos/sTIONn 
JIM FOR MA TIOW 








Figure II-4 
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Select Maneuver 


MoD < O 
Mop = 0 1G0O 
ey moo=2 —>{ {TuRN } 
mop =3 —> 10D! VE 
Mod= 4 
Ces> a MOD = 5 ie ae 
Be On =. Sele 
MOO =7 SG 
Constant Course Section Mod=6 
CONVERT CouksE ———= MCR ae ne ) 
To POLAR AMGLE 


IN RADIANS 
(THETA 


Utility Section 
COMPUTE SPEED 
Nn MILES PER 
CALLIVG PERIOD 





LWAIT 






RES TURE 
MANEUVER 
CARD DATA CARP OATA 


STORE 
MANEUVER 


X= VEL: COS + X 





Y=VEL-SINe + Y 
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APPENDIX III-A 

Identification. 
Title: PRINT 
Category: On Line Display 
Programmer; E, L. Borden 
Organization: U. S. Naval Postgraduate School 
Date: April 1965 
Purpose, 
This subroutine is designed to allow users to display characters 
and/or vectors on the Data Display model dd 65. The routine 
enables the user to display data without the trouble of packing 
special words for the dd 65. 
3.1 Normal Operation, 
3.1.1 PRINT provides for entry of the medium size characters. 
Vectors of any size allowed will be entered by PRINT. 
3.1.2 In order to illustrate the usage of PRINT, assume that 
you wanted to output to the dd 65 the following message: 

"NO TRACKS UNDER YOUR CONTROL." 


In the memory of the 1604 you would have the following stored: 


Address Contents of cell 
22222 454620235 1616342 
Pe223 2220244564655 120 
P22 304.6245 120634645 
22225 2351464373000000 


PRO = 1 - right hand tube 
QO - left hand tube 


ADD = Address in dd 65 memory where message to be stored 


III-A-1l 





APPENDIX I1Ii-A 


X = X position of First Character/Vector 


Y= Y position of First Character/Vector 


tt 


To display the message on the dd 65 the following set of coding is 


necessary; 
ENA {X) SAL (PRINT+1) . 
ENA (Y) SAL (PRINT+2) . 
ENA (PRO) SAL (PRINT+3) . 
ENA (ADD) SAL (PRINT+4) . 
ENA (222228) ENQ (0) 
SLJ 4 (PRINT) ZRO:* (0) 


The address of the message to be displayed is entered in the Accunm- 
ulator and the Q-Register is set to zero for character mode or to 
minus zero for vector mode. If the argument PRINT+4 is deleted the 
address will be the next available cell in the dd 65 memory. 

3.1.3 When the main program executes the subroutine, the subroutine 
assembles the message and packs it into a designator word and sub- 
sequent string words. The packing ends when the end of the message 
is sensed, To sense the end of the message, PRINT uses two codes. 
The code OO is used to sense the end of a character message since 
this code is illegal. The code 7 is used to sense the end of a 
vector message since this code is an illegal vector code, 

3.1.4 PRINT has a built in sense for end of line and end of page. 
Before any character or vector is assembled into a word the end 

of line is sensed. If the end of the line has beén reached, the 
subroutine will reset the X position to an initial position of 

400. and the Y position will then be checked for end of page. 

If the end of page has not been reached, the Y position will be 
decreased by 12, and a new designator word wiil begin with the 


new X and Y positions. If the end of page is sensed, then the Y¥ 


J 
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position will be reset to an initial value of 377g. At this time 
the new designator word will be formed. The routine also checks 
to insure that memory is not overflowed. Before packing any 
word, a memory check is made and if it is found that memory has 
overflowed, then the memory address is reset to 002. and a new 


designator word is started. 
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Subroutine PRINT 
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SUBROUTINE PRINT PROGRAM LISTING 
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3. 


APPENDIX IV-A 
Identification. 


Title: COURSE 


Category: Course and Velocity determination 
Programmer; E. L,. Borden 
Organization: U. S. Naval Postgraduate School 


Date: April 1965 
Purpose. ° 
This subroutine is designed to take an x-velocity, a y velocity, 
and a z-position and determines a course in degrees true, a veloc- 
ity in knots, and a velocity in mach number for any z-position 
greater than zero. 
Usage. 
3.1 Normal Operation 
3.1.1 The normal calling sequence of COURSE is as follows: 

VX = X-velocity in knots 

VY = Y-velocity in knots 

CRS = Course in degrees true 

SPD = Speed in knots 


MACH = Mach number 
Z = Z-position in feet 


ENA (VX) SAL (COURSE+1) . 
ENA (vy) SAL (COURSE+2) . 
ENA (CRS) SAL (COURSE+3) . 
ENA (MACH) SAL (COURSE+4) . 
ENA (Z) SAL (COURSE+5) . 
ENA (SPD) SAL (COURSE+6) . 
SLJ 4 (COURSE ) ZRO (0) : 


3.1.2 COURSE determines course and speed in the normal manner, 


Mach number is determined by the following formula: 
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SPD(knots ) 


MACH = “661 - 2.5 x ALT(Kft ) 


The above formula is valid for ALT less than 35,000 feet. If ALT 


is greater than 35,000 feet, it is reduced to 35,000 feet. 
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Subroutine COURSE -Chart 1. 
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Subroutine COURSE Chart 2 
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